//给定单向链表的头指针和一个要删除的节点的值，定义一个函数删除该节点。 
//
// 返回删除后的链表的头节点。 
//
// 注意：此题对比原题有改动 
//
// 示例 1: 
//
// 输入: head = [4,5,1,9], val = 5
//输出: [4,1,9]
//解释: 给定你链表中值为 5 的第二个节点，那么在调用了你的函数之后，该链表应变为 4 -> 1 -> 9.
// 
//
// 示例 2: 
//
// 输入: head = [4,5,1,9], val = 1
//输出: [4,5,9]
//解释: 给定你链表中值为 1 的第三个节点，那么在调用了你的函数之后，该链表应变为 4 -> 5 -> 9.
// 
//
// 
//
// 说明： 
//
// 
// 题目保证链表中节点的值互不相同 
// 若使用 C 或 C++ 语言，你不需要 free 或 delete 被删除的节点 
// 
// Related Topics 链表 
// 👍 149 👎 0


package leetcode.editor.cn1;

//Java：删除链表的节点

import com.leetcode.entity.ListNode;

/**
 * 给定单向链表的头指针和一个要删除的节点的值，定义一个函数删除该节点。
 * <p>
 * 返回删除后的链表的头节点。
 */
public class ShanChuLianBiaoDeJieDianLcof {
    public static void main(String[] args) {
        Solution solution = new ShanChuLianBiaoDeJieDianLcof().new Solution();
        // TO TEST
        // 构造一个链表
        ListNode head = new ListNode(4);
        ListNode tmp = new ListNode(5);
        head.next = tmp;
        tmp.next = new ListNode(1);
        tmp = tmp.next;
        tmp.next = new ListNode(9);

        System.out.println(solution.deleteNode(head, 4));
    }
    //leetcode submit region begin(Prohibit modification and deletion)

    /**
     * Definition for singly-linked list.
     * public class ListNode {
     * int val;
     * ListNode next;
     * ListNode(int x) { val = x; }
     * }
     */
    class Solution {
        public ListNode deleteNode(ListNode head, int val) {
            if (head == null)
                return null;
            // 头节点相等，删除头
            if (head.val == val) {
                head = head.next;
                return head;
            }
            // 非头节点处理
            ListNode tmp = new ListNode();
            tmp.next = head;
            while (tmp.next != null) {
                if (tmp.next.val == val) {
                    tmp.next = tmp.next.next;
                    break;
                } else {
                    tmp = tmp.next;
                }
            }
            return head;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}
